package com.example.dbsample.mapper;

import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.example.dbsample.model.dto.Page;
import com.example.dbsample.model.dto.Query;

import java.util.List;

/**
 * TODO 怎么我看到DP组件里面，还需要自己去实现？
 * @param <T>
 */
public interface MyBaseMapper<T> extends BaseMapper {
    int save(T t);

    int save(Query query);


    int batchSave(List<T> entities);

    /**
     * 查询详情
     */
    T getObject(T t);

    /**
     * 根据ID查询详情
     */
    T getObjectById(Object id);

    /**
     * 更新
     * @param query
     * @return
     */
    int update(Query query);

    /**
     * 批量更新
     */
    int batchUpdate(Query query);

    /**
     * 删除
     */
    int remove(Object id);

    /**
     * 逻辑删除
     */
    int removeLogic(Object id);

    /**
     * 批量删除
     */
    int batchRemove(Object[] ids);

    /**
     * 批量逻辑删除
     */
    int batchRemoveLogic(Object[] ids);

    /**
     * 分页查询列表
     */
    List<T> listForPage(Page<T> page, Query query);


    /**
     * 查询列表
     */
    List<T> list(Query query);

    /**
     * 查询列表
     */
    List<T> list();

    /**
     * 统计
     */
    int countTotal();

    /**
     * 统计
     */
    int countTotal(Query query);
}
